package com.zheng.wechat.mp.dao.model;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

public class WechatMpActShaketicketHomeExample implements Serializable {
    protected String orderByClause;

    protected boolean distinct;

    protected List<Criteria> oredCriteria;

    private static final long serialVersionUID = 1L;

    public WechatMpActShaketicketHomeExample() {
        oredCriteria = new ArrayList<Criteria>();
    }

    public void setOrderByClause(String orderByClause) {
        this.orderByClause = orderByClause;
    }

    public String getOrderByClause() {
        return orderByClause;
    }

    public void setDistinct(boolean distinct) {
        this.distinct = distinct;
    }

    public boolean isDistinct() {
        return distinct;
    }

    public List<Criteria> getOredCriteria() {
        return oredCriteria;
    }

    public void or(Criteria criteria) {
        oredCriteria.add(criteria);
    }

    public Criteria or() {
        Criteria criteria = createCriteriaInternal();
        oredCriteria.add(criteria);
        return criteria;
    }

    public Criteria createCriteria() {
        Criteria criteria = createCriteriaInternal();
        if (oredCriteria.size() == 0) {
            oredCriteria.add(criteria);
        }
        return criteria;
    }

    protected Criteria createCriteriaInternal() {
        Criteria criteria = new Criteria();
        return criteria;
    }

    public void clear() {
        oredCriteria.clear();
        orderByClause = null;
        distinct = false;
    }

    protected abstract static class GeneratedCriteria implements Serializable {
        protected List<Criterion> criteria;

        protected GeneratedCriteria() {
            super();
            criteria = new ArrayList<Criterion>();
        }

        public boolean isValid() {
            return criteria.size() > 0;
        }

        public List<Criterion> getAllCriteria() {
            return criteria;
        }

        public List<Criterion> getCriteria() {
            return criteria;
        }

        protected void addCriterion(String condition) {
            if (condition == null) {
                throw new RuntimeException("Value for condition cannot be null");
            }
            criteria.add(new Criterion(condition));
        }

        protected void addCriterion(String condition, Object value, String property) {
            if (value == null) {
                throw new RuntimeException("Value for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value));
        }

        protected void addCriterion(String condition, Object value1, Object value2, String property) {
            if (value1 == null || value2 == null) {
                throw new RuntimeException("Between values for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value1, value2));
        }

        public Criteria andIdIsNull() {
            addCriterion("id is null");
            return (Criteria) this;
        }

        public Criteria andIdIsNotNull() {
            addCriterion("id is not null");
            return (Criteria) this;
        }

        public Criteria andIdEqualTo(Integer value) {
            addCriterion("id =", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotEqualTo(Integer value) {
            addCriterion("id <>", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdGreaterThan(Integer value) {
            addCriterion("id >", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdGreaterThanOrEqualTo(Integer value) {
            addCriterion("id >=", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdLessThan(Integer value) {
            addCriterion("id <", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdLessThanOrEqualTo(Integer value) {
            addCriterion("id <=", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdIn(List<Integer> values) {
            addCriterion("id in", values, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotIn(List<Integer> values) {
            addCriterion("id not in", values, "id");
            return (Criteria) this;
        }

        public Criteria andIdBetween(Integer value1, Integer value2) {
            addCriterion("id between", value1, value2, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotBetween(Integer value1, Integer value2) {
            addCriterion("id not between", value1, value2, "id");
            return (Criteria) this;
        }

        public Criteria andActNameIsNull() {
            addCriterion("act_name is null");
            return (Criteria) this;
        }

        public Criteria andActNameIsNotNull() {
            addCriterion("act_name is not null");
            return (Criteria) this;
        }

        public Criteria andActNameEqualTo(String value) {
            addCriterion("act_name =", value, "actName");
            return (Criteria) this;
        }

        public Criteria andActNameNotEqualTo(String value) {
            addCriterion("act_name <>", value, "actName");
            return (Criteria) this;
        }

        public Criteria andActNameGreaterThan(String value) {
            addCriterion("act_name >", value, "actName");
            return (Criteria) this;
        }

        public Criteria andActNameGreaterThanOrEqualTo(String value) {
            addCriterion("act_name >=", value, "actName");
            return (Criteria) this;
        }

        public Criteria andActNameLessThan(String value) {
            addCriterion("act_name <", value, "actName");
            return (Criteria) this;
        }

        public Criteria andActNameLessThanOrEqualTo(String value) {
            addCriterion("act_name <=", value, "actName");
            return (Criteria) this;
        }

        public Criteria andActNameLike(String value) {
            addCriterion("act_name like", value, "actName");
            return (Criteria) this;
        }

        public Criteria andActNameNotLike(String value) {
            addCriterion("act_name not like", value, "actName");
            return (Criteria) this;
        }

        public Criteria andActNameIn(List<String> values) {
            addCriterion("act_name in", values, "actName");
            return (Criteria) this;
        }

        public Criteria andActNameNotIn(List<String> values) {
            addCriterion("act_name not in", values, "actName");
            return (Criteria) this;
        }

        public Criteria andActNameBetween(String value1, String value2) {
            addCriterion("act_name between", value1, value2, "actName");
            return (Criteria) this;
        }

        public Criteria andActNameNotBetween(String value1, String value2) {
            addCriterion("act_name not between", value1, value2, "actName");
            return (Criteria) this;
        }

        public Criteria andActiveFlagIsNull() {
            addCriterion("active_flag is null");
            return (Criteria) this;
        }

        public Criteria andActiveFlagIsNotNull() {
            addCriterion("active_flag is not null");
            return (Criteria) this;
        }

        public Criteria andActiveFlagEqualTo(String value) {
            addCriterion("active_flag =", value, "activeFlag");
            return (Criteria) this;
        }

        public Criteria andActiveFlagNotEqualTo(String value) {
            addCriterion("active_flag <>", value, "activeFlag");
            return (Criteria) this;
        }

        public Criteria andActiveFlagGreaterThan(String value) {
            addCriterion("active_flag >", value, "activeFlag");
            return (Criteria) this;
        }

        public Criteria andActiveFlagGreaterThanOrEqualTo(String value) {
            addCriterion("active_flag >=", value, "activeFlag");
            return (Criteria) this;
        }

        public Criteria andActiveFlagLessThan(String value) {
            addCriterion("active_flag <", value, "activeFlag");
            return (Criteria) this;
        }

        public Criteria andActiveFlagLessThanOrEqualTo(String value) {
            addCriterion("active_flag <=", value, "activeFlag");
            return (Criteria) this;
        }

        public Criteria andActiveFlagLike(String value) {
            addCriterion("active_flag like", value, "activeFlag");
            return (Criteria) this;
        }

        public Criteria andActiveFlagNotLike(String value) {
            addCriterion("active_flag not like", value, "activeFlag");
            return (Criteria) this;
        }

        public Criteria andActiveFlagIn(List<String> values) {
            addCriterion("active_flag in", values, "activeFlag");
            return (Criteria) this;
        }

        public Criteria andActiveFlagNotIn(List<String> values) {
            addCriterion("active_flag not in", values, "activeFlag");
            return (Criteria) this;
        }

        public Criteria andActiveFlagBetween(String value1, String value2) {
            addCriterion("active_flag between", value1, value2, "activeFlag");
            return (Criteria) this;
        }

        public Criteria andActiveFlagNotBetween(String value1, String value2) {
            addCriterion("active_flag not between", value1, value2, "activeFlag");
            return (Criteria) this;
        }

        public Criteria andBeginTimeIsNull() {
            addCriterion("begin_time is null");
            return (Criteria) this;
        }

        public Criteria andBeginTimeIsNotNull() {
            addCriterion("begin_time is not null");
            return (Criteria) this;
        }

        public Criteria andBeginTimeEqualTo(Date value) {
            addCriterion("begin_time =", value, "beginTime");
            return (Criteria) this;
        }

        public Criteria andBeginTimeNotEqualTo(Date value) {
            addCriterion("begin_time <>", value, "beginTime");
            return (Criteria) this;
        }

        public Criteria andBeginTimeGreaterThan(Date value) {
            addCriterion("begin_time >", value, "beginTime");
            return (Criteria) this;
        }

        public Criteria andBeginTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("begin_time >=", value, "beginTime");
            return (Criteria) this;
        }

        public Criteria andBeginTimeLessThan(Date value) {
            addCriterion("begin_time <", value, "beginTime");
            return (Criteria) this;
        }

        public Criteria andBeginTimeLessThanOrEqualTo(Date value) {
            addCriterion("begin_time <=", value, "beginTime");
            return (Criteria) this;
        }

        public Criteria andBeginTimeIn(List<Date> values) {
            addCriterion("begin_time in", values, "beginTime");
            return (Criteria) this;
        }

        public Criteria andBeginTimeNotIn(List<Date> values) {
            addCriterion("begin_time not in", values, "beginTime");
            return (Criteria) this;
        }

        public Criteria andBeginTimeBetween(Date value1, Date value2) {
            addCriterion("begin_time between", value1, value2, "beginTime");
            return (Criteria) this;
        }

        public Criteria andBeginTimeNotBetween(Date value1, Date value2) {
            addCriterion("begin_time not between", value1, value2, "beginTime");
            return (Criteria) this;
        }

        public Criteria andEndTimeIsNull() {
            addCriterion("end_time is null");
            return (Criteria) this;
        }

        public Criteria andEndTimeIsNotNull() {
            addCriterion("end_time is not null");
            return (Criteria) this;
        }

        public Criteria andEndTimeEqualTo(Date value) {
            addCriterion("end_time =", value, "endTime");
            return (Criteria) this;
        }

        public Criteria andEndTimeNotEqualTo(Date value) {
            addCriterion("end_time <>", value, "endTime");
            return (Criteria) this;
        }

        public Criteria andEndTimeGreaterThan(Date value) {
            addCriterion("end_time >", value, "endTime");
            return (Criteria) this;
        }

        public Criteria andEndTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("end_time >=", value, "endTime");
            return (Criteria) this;
        }

        public Criteria andEndTimeLessThan(Date value) {
            addCriterion("end_time <", value, "endTime");
            return (Criteria) this;
        }

        public Criteria andEndTimeLessThanOrEqualTo(Date value) {
            addCriterion("end_time <=", value, "endTime");
            return (Criteria) this;
        }

        public Criteria andEndTimeIn(List<Date> values) {
            addCriterion("end_time in", values, "endTime");
            return (Criteria) this;
        }

        public Criteria andEndTimeNotIn(List<Date> values) {
            addCriterion("end_time not in", values, "endTime");
            return (Criteria) this;
        }

        public Criteria andEndTimeBetween(Date value1, Date value2) {
            addCriterion("end_time between", value1, value2, "endTime");
            return (Criteria) this;
        }

        public Criteria andEndTimeNotBetween(Date value1, Date value2) {
            addCriterion("end_time not between", value1, value2, "endTime");
            return (Criteria) this;
        }

        public Criteria andDeadlinetimeIsNull() {
            addCriterion("deadlinetime is null");
            return (Criteria) this;
        }

        public Criteria andDeadlinetimeIsNotNull() {
            addCriterion("deadlinetime is not null");
            return (Criteria) this;
        }

        public Criteria andDeadlinetimeEqualTo(Date value) {
            addCriterion("deadlinetime =", value, "deadlinetime");
            return (Criteria) this;
        }

        public Criteria andDeadlinetimeNotEqualTo(Date value) {
            addCriterion("deadlinetime <>", value, "deadlinetime");
            return (Criteria) this;
        }

        public Criteria andDeadlinetimeGreaterThan(Date value) {
            addCriterion("deadlinetime >", value, "deadlinetime");
            return (Criteria) this;
        }

        public Criteria andDeadlinetimeGreaterThanOrEqualTo(Date value) {
            addCriterion("deadlinetime >=", value, "deadlinetime");
            return (Criteria) this;
        }

        public Criteria andDeadlinetimeLessThan(Date value) {
            addCriterion("deadlinetime <", value, "deadlinetime");
            return (Criteria) this;
        }

        public Criteria andDeadlinetimeLessThanOrEqualTo(Date value) {
            addCriterion("deadlinetime <=", value, "deadlinetime");
            return (Criteria) this;
        }

        public Criteria andDeadlinetimeIn(List<Date> values) {
            addCriterion("deadlinetime in", values, "deadlinetime");
            return (Criteria) this;
        }

        public Criteria andDeadlinetimeNotIn(List<Date> values) {
            addCriterion("deadlinetime not in", values, "deadlinetime");
            return (Criteria) this;
        }

        public Criteria andDeadlinetimeBetween(Date value1, Date value2) {
            addCriterion("deadlinetime between", value1, value2, "deadlinetime");
            return (Criteria) this;
        }

        public Criteria andDeadlinetimeNotBetween(Date value1, Date value2) {
            addCriterion("deadlinetime not between", value1, value2, "deadlinetime");
            return (Criteria) this;
        }

        public Criteria andTemplateIsNull() {
            addCriterion("template is null");
            return (Criteria) this;
        }

        public Criteria andTemplateIsNotNull() {
            addCriterion("template is not null");
            return (Criteria) this;
        }

        public Criteria andTemplateEqualTo(String value) {
            addCriterion("template =", value, "template");
            return (Criteria) this;
        }

        public Criteria andTemplateNotEqualTo(String value) {
            addCriterion("template <>", value, "template");
            return (Criteria) this;
        }

        public Criteria andTemplateGreaterThan(String value) {
            addCriterion("template >", value, "template");
            return (Criteria) this;
        }

        public Criteria andTemplateGreaterThanOrEqualTo(String value) {
            addCriterion("template >=", value, "template");
            return (Criteria) this;
        }

        public Criteria andTemplateLessThan(String value) {
            addCriterion("template <", value, "template");
            return (Criteria) this;
        }

        public Criteria andTemplateLessThanOrEqualTo(String value) {
            addCriterion("template <=", value, "template");
            return (Criteria) this;
        }

        public Criteria andTemplateLike(String value) {
            addCriterion("template like", value, "template");
            return (Criteria) this;
        }

        public Criteria andTemplateNotLike(String value) {
            addCriterion("template not like", value, "template");
            return (Criteria) this;
        }

        public Criteria andTemplateIn(List<String> values) {
            addCriterion("template in", values, "template");
            return (Criteria) this;
        }

        public Criteria andTemplateNotIn(List<String> values) {
            addCriterion("template not in", values, "template");
            return (Criteria) this;
        }

        public Criteria andTemplateBetween(String value1, String value2) {
            addCriterion("template between", value1, value2, "template");
            return (Criteria) this;
        }

        public Criteria andTemplateNotBetween(String value1, String value2) {
            addCriterion("template not between", value1, value2, "template");
            return (Criteria) this;
        }

        public Criteria andCountIsNull() {
            addCriterion("count is null");
            return (Criteria) this;
        }

        public Criteria andCountIsNotNull() {
            addCriterion("count is not null");
            return (Criteria) this;
        }

        public Criteria andCountEqualTo(Integer value) {
            addCriterion("count =", value, "count");
            return (Criteria) this;
        }

        public Criteria andCountNotEqualTo(Integer value) {
            addCriterion("count <>", value, "count");
            return (Criteria) this;
        }

        public Criteria andCountGreaterThan(Integer value) {
            addCriterion("count >", value, "count");
            return (Criteria) this;
        }

        public Criteria andCountGreaterThanOrEqualTo(Integer value) {
            addCriterion("count >=", value, "count");
            return (Criteria) this;
        }

        public Criteria andCountLessThan(Integer value) {
            addCriterion("count <", value, "count");
            return (Criteria) this;
        }

        public Criteria andCountLessThanOrEqualTo(Integer value) {
            addCriterion("count <=", value, "count");
            return (Criteria) this;
        }

        public Criteria andCountIn(List<Integer> values) {
            addCriterion("count in", values, "count");
            return (Criteria) this;
        }

        public Criteria andCountNotIn(List<Integer> values) {
            addCriterion("count not in", values, "count");
            return (Criteria) this;
        }

        public Criteria andCountBetween(Integer value1, Integer value2) {
            addCriterion("count between", value1, value2, "count");
            return (Criteria) this;
        }

        public Criteria andCountNotBetween(Integer value1, Integer value2) {
            addCriterion("count not between", value1, value2, "count");
            return (Criteria) this;
        }

        public Criteria andNumPerDayIsNull() {
            addCriterion("num_per_day is null");
            return (Criteria) this;
        }

        public Criteria andNumPerDayIsNotNull() {
            addCriterion("num_per_day is not null");
            return (Criteria) this;
        }

        public Criteria andNumPerDayEqualTo(Integer value) {
            addCriterion("num_per_day =", value, "numPerDay");
            return (Criteria) this;
        }

        public Criteria andNumPerDayNotEqualTo(Integer value) {
            addCriterion("num_per_day <>", value, "numPerDay");
            return (Criteria) this;
        }

        public Criteria andNumPerDayGreaterThan(Integer value) {
            addCriterion("num_per_day >", value, "numPerDay");
            return (Criteria) this;
        }

        public Criteria andNumPerDayGreaterThanOrEqualTo(Integer value) {
            addCriterion("num_per_day >=", value, "numPerDay");
            return (Criteria) this;
        }

        public Criteria andNumPerDayLessThan(Integer value) {
            addCriterion("num_per_day <", value, "numPerDay");
            return (Criteria) this;
        }

        public Criteria andNumPerDayLessThanOrEqualTo(Integer value) {
            addCriterion("num_per_day <=", value, "numPerDay");
            return (Criteria) this;
        }

        public Criteria andNumPerDayIn(List<Integer> values) {
            addCriterion("num_per_day in", values, "numPerDay");
            return (Criteria) this;
        }

        public Criteria andNumPerDayNotIn(List<Integer> values) {
            addCriterion("num_per_day not in", values, "numPerDay");
            return (Criteria) this;
        }

        public Criteria andNumPerDayBetween(Integer value1, Integer value2) {
            addCriterion("num_per_day between", value1, value2, "numPerDay");
            return (Criteria) this;
        }

        public Criteria andNumPerDayNotBetween(Integer value1, Integer value2) {
            addCriterion("num_per_day not between", value1, value2, "numPerDay");
            return (Criteria) this;
        }

        public Criteria andHdurlIsNull() {
            addCriterion("hdurl is null");
            return (Criteria) this;
        }

        public Criteria andHdurlIsNotNull() {
            addCriterion("hdurl is not null");
            return (Criteria) this;
        }

        public Criteria andHdurlEqualTo(String value) {
            addCriterion("hdurl =", value, "hdurl");
            return (Criteria) this;
        }

        public Criteria andHdurlNotEqualTo(String value) {
            addCriterion("hdurl <>", value, "hdurl");
            return (Criteria) this;
        }

        public Criteria andHdurlGreaterThan(String value) {
            addCriterion("hdurl >", value, "hdurl");
            return (Criteria) this;
        }

        public Criteria andHdurlGreaterThanOrEqualTo(String value) {
            addCriterion("hdurl >=", value, "hdurl");
            return (Criteria) this;
        }

        public Criteria andHdurlLessThan(String value) {
            addCriterion("hdurl <", value, "hdurl");
            return (Criteria) this;
        }

        public Criteria andHdurlLessThanOrEqualTo(String value) {
            addCriterion("hdurl <=", value, "hdurl");
            return (Criteria) this;
        }

        public Criteria andHdurlLike(String value) {
            addCriterion("hdurl like", value, "hdurl");
            return (Criteria) this;
        }

        public Criteria andHdurlNotLike(String value) {
            addCriterion("hdurl not like", value, "hdurl");
            return (Criteria) this;
        }

        public Criteria andHdurlIn(List<String> values) {
            addCriterion("hdurl in", values, "hdurl");
            return (Criteria) this;
        }

        public Criteria andHdurlNotIn(List<String> values) {
            addCriterion("hdurl not in", values, "hdurl");
            return (Criteria) this;
        }

        public Criteria andHdurlBetween(String value1, String value2) {
            addCriterion("hdurl between", value1, value2, "hdurl");
            return (Criteria) this;
        }

        public Criteria andHdurlNotBetween(String value1, String value2) {
            addCriterion("hdurl not between", value1, value2, "hdurl");
            return (Criteria) this;
        }

        public Criteria andShortUrlIsNull() {
            addCriterion("short_url is null");
            return (Criteria) this;
        }

        public Criteria andShortUrlIsNotNull() {
            addCriterion("short_url is not null");
            return (Criteria) this;
        }

        public Criteria andShortUrlEqualTo(String value) {
            addCriterion("short_url =", value, "shortUrl");
            return (Criteria) this;
        }

        public Criteria andShortUrlNotEqualTo(String value) {
            addCriterion("short_url <>", value, "shortUrl");
            return (Criteria) this;
        }

        public Criteria andShortUrlGreaterThan(String value) {
            addCriterion("short_url >", value, "shortUrl");
            return (Criteria) this;
        }

        public Criteria andShortUrlGreaterThanOrEqualTo(String value) {
            addCriterion("short_url >=", value, "shortUrl");
            return (Criteria) this;
        }

        public Criteria andShortUrlLessThan(String value) {
            addCriterion("short_url <", value, "shortUrl");
            return (Criteria) this;
        }

        public Criteria andShortUrlLessThanOrEqualTo(String value) {
            addCriterion("short_url <=", value, "shortUrl");
            return (Criteria) this;
        }

        public Criteria andShortUrlLike(String value) {
            addCriterion("short_url like", value, "shortUrl");
            return (Criteria) this;
        }

        public Criteria andShortUrlNotLike(String value) {
            addCriterion("short_url not like", value, "shortUrl");
            return (Criteria) this;
        }

        public Criteria andShortUrlIn(List<String> values) {
            addCriterion("short_url in", values, "shortUrl");
            return (Criteria) this;
        }

        public Criteria andShortUrlNotIn(List<String> values) {
            addCriterion("short_url not in", values, "shortUrl");
            return (Criteria) this;
        }

        public Criteria andShortUrlBetween(String value1, String value2) {
            addCriterion("short_url between", value1, value2, "shortUrl");
            return (Criteria) this;
        }

        public Criteria andShortUrlNotBetween(String value1, String value2) {
            addCriterion("short_url not between", value1, value2, "shortUrl");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinIsNull() {
            addCriterion("foucs_user_can_join is null");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinIsNotNull() {
            addCriterion("foucs_user_can_join is not null");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinEqualTo(String value) {
            addCriterion("foucs_user_can_join =", value, "foucsUserCanJoin");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinNotEqualTo(String value) {
            addCriterion("foucs_user_can_join <>", value, "foucsUserCanJoin");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinGreaterThan(String value) {
            addCriterion("foucs_user_can_join >", value, "foucsUserCanJoin");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinGreaterThanOrEqualTo(String value) {
            addCriterion("foucs_user_can_join >=", value, "foucsUserCanJoin");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinLessThan(String value) {
            addCriterion("foucs_user_can_join <", value, "foucsUserCanJoin");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinLessThanOrEqualTo(String value) {
            addCriterion("foucs_user_can_join <=", value, "foucsUserCanJoin");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinLike(String value) {
            addCriterion("foucs_user_can_join like", value, "foucsUserCanJoin");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinNotLike(String value) {
            addCriterion("foucs_user_can_join not like", value, "foucsUserCanJoin");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinIn(List<String> values) {
            addCriterion("foucs_user_can_join in", values, "foucsUserCanJoin");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinNotIn(List<String> values) {
            addCriterion("foucs_user_can_join not in", values, "foucsUserCanJoin");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinBetween(String value1, String value2) {
            addCriterion("foucs_user_can_join between", value1, value2, "foucsUserCanJoin");
            return (Criteria) this;
        }

        public Criteria andFoucsUserCanJoinNotBetween(String value1, String value2) {
            addCriterion("foucs_user_can_join not between", value1, value2, "foucsUserCanJoin");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinIsNull() {
            addCriterion("binding_mobile_can_join is null");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinIsNotNull() {
            addCriterion("binding_mobile_can_join is not null");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinEqualTo(String value) {
            addCriterion("binding_mobile_can_join =", value, "bindingMobileCanJoin");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinNotEqualTo(String value) {
            addCriterion("binding_mobile_can_join <>", value, "bindingMobileCanJoin");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinGreaterThan(String value) {
            addCriterion("binding_mobile_can_join >", value, "bindingMobileCanJoin");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinGreaterThanOrEqualTo(String value) {
            addCriterion("binding_mobile_can_join >=", value, "bindingMobileCanJoin");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinLessThan(String value) {
            addCriterion("binding_mobile_can_join <", value, "bindingMobileCanJoin");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinLessThanOrEqualTo(String value) {
            addCriterion("binding_mobile_can_join <=", value, "bindingMobileCanJoin");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinLike(String value) {
            addCriterion("binding_mobile_can_join like", value, "bindingMobileCanJoin");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinNotLike(String value) {
            addCriterion("binding_mobile_can_join not like", value, "bindingMobileCanJoin");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinIn(List<String> values) {
            addCriterion("binding_mobile_can_join in", values, "bindingMobileCanJoin");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinNotIn(List<String> values) {
            addCriterion("binding_mobile_can_join not in", values, "bindingMobileCanJoin");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinBetween(String value1, String value2) {
            addCriterion("binding_mobile_can_join between", value1, value2, "bindingMobileCanJoin");
            return (Criteria) this;
        }

        public Criteria andBindingMobileCanJoinNotBetween(String value1, String value2) {
            addCriterion("binding_mobile_can_join not between", value1, value2, "bindingMobileCanJoin");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinIsNull() {
            addCriterion("win_can_join is null");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinIsNotNull() {
            addCriterion("win_can_join is not null");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinEqualTo(String value) {
            addCriterion("win_can_join =", value, "winCanJoin");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinNotEqualTo(String value) {
            addCriterion("win_can_join <>", value, "winCanJoin");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinGreaterThan(String value) {
            addCriterion("win_can_join >", value, "winCanJoin");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinGreaterThanOrEqualTo(String value) {
            addCriterion("win_can_join >=", value, "winCanJoin");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinLessThan(String value) {
            addCriterion("win_can_join <", value, "winCanJoin");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinLessThanOrEqualTo(String value) {
            addCriterion("win_can_join <=", value, "winCanJoin");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinLike(String value) {
            addCriterion("win_can_join like", value, "winCanJoin");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinNotLike(String value) {
            addCriterion("win_can_join not like", value, "winCanJoin");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinIn(List<String> values) {
            addCriterion("win_can_join in", values, "winCanJoin");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinNotIn(List<String> values) {
            addCriterion("win_can_join not in", values, "winCanJoin");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinBetween(String value1, String value2) {
            addCriterion("win_can_join between", value1, value2, "winCanJoin");
            return (Criteria) this;
        }

        public Criteria andWinCanJoinNotBetween(String value1, String value2) {
            addCriterion("win_can_join not between", value1, value2, "winCanJoin");
            return (Criteria) this;
        }

        public Criteria andJwidIsNull() {
            addCriterion("jwid is null");
            return (Criteria) this;
        }

        public Criteria andJwidIsNotNull() {
            addCriterion("jwid is not null");
            return (Criteria) this;
        }

        public Criteria andJwidEqualTo(String value) {
            addCriterion("jwid =", value, "jwid");
            return (Criteria) this;
        }

        public Criteria andJwidNotEqualTo(String value) {
            addCriterion("jwid <>", value, "jwid");
            return (Criteria) this;
        }

        public Criteria andJwidGreaterThan(String value) {
            addCriterion("jwid >", value, "jwid");
            return (Criteria) this;
        }

        public Criteria andJwidGreaterThanOrEqualTo(String value) {
            addCriterion("jwid >=", value, "jwid");
            return (Criteria) this;
        }

        public Criteria andJwidLessThan(String value) {
            addCriterion("jwid <", value, "jwid");
            return (Criteria) this;
        }

        public Criteria andJwidLessThanOrEqualTo(String value) {
            addCriterion("jwid <=", value, "jwid");
            return (Criteria) this;
        }

        public Criteria andJwidLike(String value) {
            addCriterion("jwid like", value, "jwid");
            return (Criteria) this;
        }

        public Criteria andJwidNotLike(String value) {
            addCriterion("jwid not like", value, "jwid");
            return (Criteria) this;
        }

        public Criteria andJwidIn(List<String> values) {
            addCriterion("jwid in", values, "jwid");
            return (Criteria) this;
        }

        public Criteria andJwidNotIn(List<String> values) {
            addCriterion("jwid not in", values, "jwid");
            return (Criteria) this;
        }

        public Criteria andJwidBetween(String value1, String value2) {
            addCriterion("jwid between", value1, value2, "jwid");
            return (Criteria) this;
        }

        public Criteria andJwidNotBetween(String value1, String value2) {
            addCriterion("jwid not between", value1, value2, "jwid");
            return (Criteria) this;
        }

        public Criteria andProjectCodeIsNull() {
            addCriterion("project_code is null");
            return (Criteria) this;
        }

        public Criteria andProjectCodeIsNotNull() {
            addCriterion("project_code is not null");
            return (Criteria) this;
        }

        public Criteria andProjectCodeEqualTo(String value) {
            addCriterion("project_code =", value, "projectCode");
            return (Criteria) this;
        }

        public Criteria andProjectCodeNotEqualTo(String value) {
            addCriterion("project_code <>", value, "projectCode");
            return (Criteria) this;
        }

        public Criteria andProjectCodeGreaterThan(String value) {
            addCriterion("project_code >", value, "projectCode");
            return (Criteria) this;
        }

        public Criteria andProjectCodeGreaterThanOrEqualTo(String value) {
            addCriterion("project_code >=", value, "projectCode");
            return (Criteria) this;
        }

        public Criteria andProjectCodeLessThan(String value) {
            addCriterion("project_code <", value, "projectCode");
            return (Criteria) this;
        }

        public Criteria andProjectCodeLessThanOrEqualTo(String value) {
            addCriterion("project_code <=", value, "projectCode");
            return (Criteria) this;
        }

        public Criteria andProjectCodeLike(String value) {
            addCriterion("project_code like", value, "projectCode");
            return (Criteria) this;
        }

        public Criteria andProjectCodeNotLike(String value) {
            addCriterion("project_code not like", value, "projectCode");
            return (Criteria) this;
        }

        public Criteria andProjectCodeIn(List<String> values) {
            addCriterion("project_code in", values, "projectCode");
            return (Criteria) this;
        }

        public Criteria andProjectCodeNotIn(List<String> values) {
            addCriterion("project_code not in", values, "projectCode");
            return (Criteria) this;
        }

        public Criteria andProjectCodeBetween(String value1, String value2) {
            addCriterion("project_code between", value1, value2, "projectCode");
            return (Criteria) this;
        }

        public Criteria andProjectCodeNotBetween(String value1, String value2) {
            addCriterion("project_code not between", value1, value2, "projectCode");
            return (Criteria) this;
        }

        public Criteria andCreateByIsNull() {
            addCriterion("create_by is null");
            return (Criteria) this;
        }

        public Criteria andCreateByIsNotNull() {
            addCriterion("create_by is not null");
            return (Criteria) this;
        }

        public Criteria andCreateByEqualTo(String value) {
            addCriterion("create_by =", value, "createBy");
            return (Criteria) this;
        }

        public Criteria andCreateByNotEqualTo(String value) {
            addCriterion("create_by <>", value, "createBy");
            return (Criteria) this;
        }

        public Criteria andCreateByGreaterThan(String value) {
            addCriterion("create_by >", value, "createBy");
            return (Criteria) this;
        }

        public Criteria andCreateByGreaterThanOrEqualTo(String value) {
            addCriterion("create_by >=", value, "createBy");
            return (Criteria) this;
        }

        public Criteria andCreateByLessThan(String value) {
            addCriterion("create_by <", value, "createBy");
            return (Criteria) this;
        }

        public Criteria andCreateByLessThanOrEqualTo(String value) {
            addCriterion("create_by <=", value, "createBy");
            return (Criteria) this;
        }

        public Criteria andCreateByLike(String value) {
            addCriterion("create_by like", value, "createBy");
            return (Criteria) this;
        }

        public Criteria andCreateByNotLike(String value) {
            addCriterion("create_by not like", value, "createBy");
            return (Criteria) this;
        }

        public Criteria andCreateByIn(List<String> values) {
            addCriterion("create_by in", values, "createBy");
            return (Criteria) this;
        }

        public Criteria andCreateByNotIn(List<String> values) {
            addCriterion("create_by not in", values, "createBy");
            return (Criteria) this;
        }

        public Criteria andCreateByBetween(String value1, String value2) {
            addCriterion("create_by between", value1, value2, "createBy");
            return (Criteria) this;
        }

        public Criteria andCreateByNotBetween(String value1, String value2) {
            addCriterion("create_by not between", value1, value2, "createBy");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIsNull() {
            addCriterion("create_time is null");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIsNotNull() {
            addCriterion("create_time is not null");
            return (Criteria) this;
        }

        public Criteria andCreateTimeEqualTo(Date value) {
            addCriterion("create_time =", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotEqualTo(Date value) {
            addCriterion("create_time <>", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeGreaterThan(Date value) {
            addCriterion("create_time >", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("create_time >=", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeLessThan(Date value) {
            addCriterion("create_time <", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeLessThanOrEqualTo(Date value) {
            addCriterion("create_time <=", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIn(List<Date> values) {
            addCriterion("create_time in", values, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotIn(List<Date> values) {
            addCriterion("create_time not in", values, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeBetween(Date value1, Date value2) {
            addCriterion("create_time between", value1, value2, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotBetween(Date value1, Date value2) {
            addCriterion("create_time not between", value1, value2, "createTime");
            return (Criteria) this;
        }
    }

    public static class Criteria extends GeneratedCriteria implements Serializable {

        protected Criteria() {
            super();
        }
    }

    public static class Criterion implements Serializable {
        private String condition;

        private Object value;

        private Object secondValue;

        private boolean noValue;

        private boolean singleValue;

        private boolean betweenValue;

        private boolean listValue;

        private String typeHandler;

        public String getCondition() {
            return condition;
        }

        public Object getValue() {
            return value;
        }

        public Object getSecondValue() {
            return secondValue;
        }

        public boolean isNoValue() {
            return noValue;
        }

        public boolean isSingleValue() {
            return singleValue;
        }

        public boolean isBetweenValue() {
            return betweenValue;
        }

        public boolean isListValue() {
            return listValue;
        }

        public String getTypeHandler() {
            return typeHandler;
        }

        protected Criterion(String condition) {
            super();
            this.condition = condition;
            this.typeHandler = null;
            this.noValue = true;
        }

        protected Criterion(String condition, Object value, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.typeHandler = typeHandler;
            if (value instanceof List<?>) {
                this.listValue = true;
            } else {
                this.singleValue = true;
            }
        }

        protected Criterion(String condition, Object value) {
            this(condition, value, null);
        }

        protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.secondValue = secondValue;
            this.typeHandler = typeHandler;
            this.betweenValue = true;
        }

        protected Criterion(String condition, Object value, Object secondValue) {
            this(condition, value, secondValue, null);
        }
    }
}